草庐IT

lua - redis-lua 在需要时返回 nil

全部标签

ruby - 为什么需要 "require ' bundler/setup'”?

在我见过的几乎所有Sinatra示例中,不管它做了什么,它总是有以下两行:require'rubygems'require'bundler/setup'在大多数示例中,删除“bundler/setup”要求似乎没有破坏效果,所以我对何时何地需要包含它感到困惑。我讨厌在不知道确切原因的情况下使用东西,所以我希望有人能解释为什么我需要这两条线以及它们的作用? 最佳答案 它确保您正在加载Gemfile定义的gem。请在此处查看文档https://bundler.io/v1.12/bundler_setup.html

ruby - 如何在需要必要的库和/或 header 时安装 ruby​​-debug

我的Rails是3.2.1.4,Ruby是1.9.3p448。我在安装ruby-debug时遇到错误:Buildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingruby-debug:ERROR:Failedtobuildgemnativeextension./home/hxh/.rvm/rubies/ruby-1.9.3-p448/bin/rubyextconf.rbCan'thandle1.9.xyet***extconf.rbfailed***CouldnotcreateMakefileduetosome

ruby-on-rails - 如何在不重复 nil 检查的情况下避免嵌套哈希中缺少元素的 NoMethodError?

我正在寻找一种避免在深度嵌套的哈希中的每个级别检查nil的好方法。例如:name=params[:company][:owner][:name]ifparams[:company]&¶ms[:company][:owner]&¶ms[:company][:owner][:name]这需要三项检查,并且代码非常丑陋。有什么办法可以解决这个问题? 最佳答案 引入了Ruby2.3.0amethodcalleddig在Hash和Array上。name=params.dig(:company,:owner,:name)如果在任

ruby - 安装 Jekyll 时出错,需要 Ruby >= 2.0.0

我得到了错误Errorinstallingjekyll:jekyllrequiresRubyversion>=2.0.0.当我运行时sudogeminstalljekyll“ruby-v”表示我有ruby​​版本1.9.3如何安装Jekyll?我需要升级ruby吗?如果是,怎么办?更新-我用rvm安装了ruby​​2.0.0但得到了同样的错误。自从尝试使用gem进行安装后,是否仍会尝试使用旧版本的ruby​​进行安装?如果有,如何发现和改变? 最佳答案 尝试sudogeminstalljekyll-v2.5默认命令显然会尝试安装已发

产生或返回 Enumerator 的 ruby​​ 方法

在最新版本的Ruby中,Enumerable中的许多方法在没有block调用时返回一个Enumerator:[1,2,3,4].map#=>#[1,2,3,4].map{|x|x*2}#=>[2,4,6,8]我想用我自己的方法做同样的事情:classArraydefdouble(&block)#???endendarr=[1,2,3,4]puts"withblock:yieldingdirectly"arr.double{|x|px}puts"withoutblock:returningEnumerator"enum=arr.doubleenum.each{|x|px}

Ruby:如果更改了文件,则再次需要一个文件

我写了一个在config/中查找配置文件的gem。这工作正常,但如果用户更改任何配置,他们必须停止程序并在我的gem加载新配置之前重新启动它。这将要求他们在每次更改时重新启动整个Rails应用程序,这并不理想。有没有办法“重新要求”一个文件,以便它重新加载它而不是使用缓存的版本。 最佳答案 您可以使用load代替require。这将加载文件,而不管它之前是否已经加载过。请注意,对于load,您需要指定.rb扩展名,它对于require是可选的。所以require"path/to/myconfig"变成了load"path/to/my

ruby-on-rails - 为什么我需要更加努力地使我的 Rails 应用程序适应 RESTful 架构?

我最近开始了一个Rails项目,并决定使用RESTfulController。我为我的关键实体(例如国家/地区)创建了Controller并添加了index、new、edit、create、显示、更新和删除。我将我的map.resources:country添加到我的路线文件中,生活很美好。开发稍有进展后,就开始遇到问题了。我有时需要在我的Controller中执行额外的操作。首先是search操作,它返回我喜欢的自动完成搜索框的选项。然后需要在应用程序的不同位置以两种不同的方式显示国家/地区(显示的数据也不同,所以它不仅仅是两个View)-我添加了index_full操作。然后我想在

ruby - 类似 tap 的组合方法,但能够返回不同的值?

我正在经历一个尝试避免临时变量和过度使用条件的阶段,在这个阶段我可以使用更流畅的编码风格。我非常喜欢在想要获取需要返回的值的地方使用#tap,但在返回它之前对其进行一些处理。deffluid_methodsomething_complicated(a,b,c).tapdo|obj|obj.update(:x=>y)endendvs。程序:defnon_fluid_methodobj=something_complicated(a,b,c)obj.update(:x=>y)obj#显然上面的示例很简单,但这在ruby​​社区中仍然是一种非常常见的编码风格。有时我也会使用#inject通过

ruby-on-rails - 强参数需要多个

我收到一个JSON包,例如:{"point_code":{"guid":"f6a0805a-3404-403c-8af3-bfddf9d334f2"}}我想告诉Railspoint_code和guid都是必需的,而不仅仅是允许的。这段代码似乎可以工作,但我认为这不是一个好习惯,因为它返回的是一个字符串,而不是完整的对象:params.require(:point_code).require(:guid)有什么想法可以做到这一点吗? 最佳答案 我有类似的需求,我所做的是defpoint_code_paramsparams.requir

ruby-on-rails - Rails 开发服务器很慢,需要很长时间才能加载一个简单的页面

关于Rails在开发模式下运行缓慢的类似帖子也有,但这些帖子中的解决方案都没有对我产生任何影响。我试过安装可以提高性能的gem并修改配置文件,但都没有成功。我刚开始使用Rails,所以我正在运行“Rails入门”指南中的启动应用程序,这是一个小博客。我已经按照推荐安装了Ruby1.9.3和Rails3.2.13。我在OS/X10.7.5上运行。当加载教程应用的起始页时,实际上只有1行文本和1个链接,需要20-40秒。对任何页面的每个后续请求都需要20-40秒。然而,当我查看服务器日志时,Rails所做的任何事情似乎都不会花费很长时间。日志中的事件之间的时间一直在占用。作为Rails的初